package com.huya.mapper;

import com.huya.pojo.dto.UserUpdateDTO;
import com.huya.pojo.entity.User;
import com.huya.pojo.vo.UserVO;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;

import java.util.Map;

@Mapper
public interface UserMapper {
    /**
     * 根据openid查询用户信息
     * @param openid
     * @return
     */
    @Select("SELECT * FROM user WHERE openid = #{openId}")
    User getByOpenid(String openid);

    /**
     * 插入用户
     * @param user
     */
    void insert(User user);

    void update(UserUpdateDTO userUpdateDTO);

    @Update("UPDATE user SET phone = #{phone} WHERE id = #{id}")
    void updateUserPhone(Long id, String phone);


    /**
     * 根据id查询用户信息
     * @param id
     * @return
     */
    @Select("SELECT * FROM user WHERE id = #{id}")
    User findById(Long id);

    /**
     * 根据条件查询用户数量
     * @param map
     * @return
     */
    Integer countByMap(Map map);
}
